#### 21.4 TIM2/TIM3/TIM4 registers

Refer to Section 2.1 for a list of abbreviations used in register descriptions.

The peripheral registers can be accessed by half-words (16-bit) or words (32-bit).

#### 21.4.1 TIMx control register 1 (TIMx\_CR1)

Address offset: 0x00 Reset value: 0x0000

| 15   | 14   | 13   | 12   | 11                | 10   | 9   | 8      | 7    | 6  | 5  | 4   | 3   | 2   | 1    | 0   |
|------|------|------|------|-------------------|------|-----|--------|------|----|----|-----|-----|-----|------|-----|
| Res. | Res. | Res. | Res. | UIF<br>RE-<br>MAP | Res. | CKE | 0[1:0] | ARPE | CI | ИS | DIR | ОРМ | URS | UDIS | CEN |
|      |      |      |      | rw                |      | rw  | rw     | rw   | rw | rw | rw  | rw  | rw  | rw   | rw  |

Bits 15:12 Reserved, must be kept at reset value.

## Bit 11 **UIFREMAP**: UIF status bit remapping

- 0: No remapping. UIF status bit is not copied to TIMx\_CNT register bit 31.
- 1: Remapping enabled. UIF status bit is copied to TIMx\_CNT register bit 31.
- Bit 10 Reserved, must be kept at reset value.

### Bits 9:8 CKD: Clock division

This bit-field indicates the division ratio between the timer clock (CK\_INT) frequency and sampling clock used by the digital filters (ETR, Tlx),

00:  $t_{DTS} = t_{CK \ INT}$ 

01:  $t_{DTS} = 2 \times t_{CK\_INT}$ 10:  $t_{DTS} = 4 \times t_{CK\_INT}$ 

11: Reserved

## Bit 7 ARPE: Auto-reload preload enable

0: TIMx ARR register is not buffered

1: TIMx ARR register is buffered

### Bits 6:5 CMS: Center-aligned mode selection

00: Edge-aligned mode. The counter counts up or down depending on the direction bit

01: Center-aligned mode 1. The counter counts up and down alternatively. Output compare interrupt flags of channels configured in output (CCxS=00 in TIMx\_CCMRx register) are set only when the counter is counting down.

10: Center-aligned mode 2. The counter counts up and down alternatively. Output compare interrupt flags of channels configured in output (CCxS=00 in TIMx CCMRx register) are set only when the counter is counting up.

11: Center-aligned mode 3. The counter counts up and down alternatively. Output compare interrupt flags of channels configured in output (CCxS=00 in TIMx CCMRx register) are set both when the counter is counting up or down.

Note: It is not allowed to switch from edge-aligned mode to center-aligned mode as long as the counter is enabled (CEN=1)

### Bit 4 DIR: Direction

- 0: Counter used as upcounter
- 1: Counter used as downcounter

Note: This bit is read only when the timer is configured in Center-aligned mode or Encoder mode.



### Bit 3 OPM: One-pulse mode

- 0: Counter is not stopped at update event
- 1: Counter stops counting at the next update event (clearing the bit CEN)

#### Bit 2 **URS**: Update request source

This bit is set and cleared by software to select the UEV event sources.

0: Any of the following events generate an update interrupt or DMA request if enabled. These events can be:

- Counter overflow/underflow
- Setting the UG bit
- Update generation through the slave mode controller
- 1: Only counter overflow/underflow generates an update interrupt or DMA request if enabled.

## Bit 1 UDIS: Update disable

This bit is set and cleared by software to enable/disable UEV event generation.

- 0: UEV enabled. The Update (UEV) event is generated by one of the following events:
  - Counter overflow/underflow
  - Setting the UG bit
  - Update generation through the slave mode controller

Buffered registers are then loaded with their preload values.

1: UEV disabled. The Update event is not generated, shadow registers keep their value (ARR, PSC, CCRx). However the counter and the prescaler are reinitialized if the UG bit is set or if a hardware reset is received from the slave mode controller.

### Bit 0 CEN: Counter enable

0: Counter disabled

1: Counter enabled

Note: External clock, gated mode and encoder mode can work only if the CEN bit has been previously set by software. However trigger mode can set the CEN bit automatically by hardware.

CEN is cleared automatically in one-pulse mode, when an update event occurs.

# 21.4.2 TIMx control register 2 (TIMx\_CR2)

Address offset: 0x04 Reset value: 0x0000

| 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6  | 5        | 4  | 3    | 2    | 1    | 0    |
|------|------|------|------|------|------|------|------|------|----|----------|----|------|------|------|------|
| Res. | TI1S |    | MMS[2:0] | ]  | CCDS | Res. | Res. | Res. |
|      |      |      |      |      |      |      |      | rw   | rw | rw       | rw | rw   |      |      |      |

Bits 15:8 Reserved, must be kept at reset value.

## Bit 7 TI1S: TI1 selection

0: The TIMx CH1 pin is connected to TI1 input

1: The TIMx\_CH1, CH2 and CH3 pins are connected to the TI1 input (XOR combination)

See also Section 20.3.24: Interfacing with Hall sensors on page 556

648/1141 DocID022558 Rev 8



#### Bits 6:4 MMS: Master mode selection

These bits allow to select the information to be sent in master mode to slave timers for synchronization (TRGO). The combination is as follows:

000: **Reset** - the UG bit from the TIMx\_EGR register is used as trigger output (TRGO). If the reset is generated by the trigger input (slave mode controller configured in reset mode) then the signal on TRGO is delayed compared to the actual reset.

001: **Enable** - the Counter enable signal, CNT\_EN, is used as trigger output (TRGO). It is useful to start several timers at the same time or to control a window in which a slave timer is enabled. The Counter Enable signal is generated by a logic OR between CEN control bit and the trigger input when configured in gated mode.

When the Counter Enable signal is controlled by the trigger input, there is a delay on TRGO, except if the master/slave mode is selected (see the MSM bit description in TIMx\_SMCR register).

010: **Update** - The update event is selected as trigger output (TRGO). For instance a master timer can then be used as a prescaler for a slave timer.

011: **Compare Pulse** - The trigger output send a positive pulse when the CC1IF flag is to be set (even if it was already high), as soon as a capture or a compare match occurred. (TRGO)

- 100: Compare OC1REF signal is used as trigger output (TRGO)
- 101: Compare OC2REF signal is used as trigger output (TRGO)
- 110: Compare OC3REF signal is used as trigger output (TRGO)
- 111: Compare OC4REF signal is used as trigger output (TRGO)

Note: The clock of the slave timer or ADC must be enabled prior to receive events from the master timer, and must not be changed on-the-fly while triggers are received from the master timer.

- Bit 3 CCDS: Capture/compare DMA selection
  - 0: CCx DMA request sent when CCx event occurs
  - 1: CCx DMA requests sent when update event occurs

Bits 2:0 Reserved, must be kept at reset value.

# 21.4.3 TIMx slave mode control register (TIMx\_SMCR)

Address offset: 0x08 Reset value: 0x0000

| 31   | 30   | 29   | 28     | 27       | 26   | 25   | 24   | 23      | 22   | 21   | 20   | 19      | 18   | 17   | 16     |
|------|------|------|--------|----------|------|------|------|---------|------|------|------|---------|------|------|--------|
| Res. | Res. | Res. | Res.   | Res.     | Res. | Res. | Res. | Res.    | Res. | Res. | Res. | Res.    | Res. | Res. | SMS[3] |
|      |      |      |        |          |      |      |      |         |      |      |      |         |      |      | rw     |
| 15   | 14   | 13   | 12     | 11       | 10   | 9    | 8    | 7       | 6    | 5    | 4    | 3       | 2    | 1    | 0      |
| ETP  | ECE  | ETPS | S[1:0] | ETF[3:0] |      | MSM  |      | TS[2:0] |      | occs |      | SMS[2:0 | ]    |      |        |
| rw   | rw   | rw   | rw     | rw       | rw   | rw   | rw   | rw      | rw   | rw   | rw   | rw      | rw   | rw   | rw     |

Bits 31:17 Reserved, must be kept at reset value.

Bit 16 **SMS[3]**: Slave mode selection - bit 3 Refer to SMS description - bits 2:0

Bit 15 ETP: External trigger polarity

This bit selects whether ETR or  $\overline{\text{ETR}}$  is used for trigger operations

- 0: ETR is non-inverted, active at high level or rising edge
- 1: ETR is inverted, active at low level or falling edge

#### Bit 14 ECE: External clock enable

This bit enables External clock mode 2.

- 0: External clock mode 2 disabled
- 1: External clock mode 2 enabled. The counter is clocked by any active edge on the ETRF signal.
- 1: Setting the ECE bit has the same effect as selecting external clock mode 1 with TRGI connected to ETRF (SMS=111 and TS=111).
- 2: It is possible to simultaneously use external clock mode 2 with the following slave modes: reset mode, gated mode and trigger mode. Nevertheless, TRGI must not be connected to ETRF in this case (TS bits must not be 111).
- **3**: If external clock mode 1 and external clock mode 2 are enabled at the same time, the external clock input is ETRF.

## Bits 13:12 ETPS[1:0]: External trigger prescaler

External trigger signal ETRP frequency must be at most 1/4 of CK\_INT frequency. A prescaler can be enabled to reduce ETRP frequency. It is useful when inputting fast external clocks.

00: Prescaler OFF

01: ETRP frequency divided by 2

10: ETRP frequency divided by 4

11: ETRP frequency divided by 8



# Bits 11:8 ETF[3:0]: External trigger filter

This bit-field then defines the frequency used to sample ETRP signal and the length of the digital filter applied to ETRP. The digital filter is made of an event counter in which N consecutive events are needed to validate a transition on the output:

```
0000: No filter, sampling is done at f<sub>DTS</sub>
```

```
0001: f<sub>SAMPLING</sub>=f<sub>CK_INT</sub>, N=2
0010: f<sub>SAMPLING</sub>=f<sub>CK_INT</sub>, N=4
0011: f<sub>SAMPLING</sub>=f<sub>CK_INT</sub>, N=8
0100: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/2, N=6
0101: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/2, N=8
0110: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/4, N=6
0111: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/4, N=8
1000: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/8, N=6
1001: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/8, N=8
1010: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/16, N=5
1011: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/16, N=6
1100: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/16, N=8
1101: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/32, N=5
1110: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/32, N=6
1111: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/32, N=8
```

## Bit 7 MSM: Master/Slave mode

#### 0: No action

1: The effect of an event on the trigger input (TRGI) is delayed to allow a perfect synchronization between the current timer and its slaves (through TRGO). It is useful if we want to synchronize several timers on a single external event.



## Bits 6:4 TS: Trigger selection

This bit-field selects the trigger input to be used to synchronize the counter.

000: Internal Trigger 0 (ITR0). reserved

001: Internal Trigger 1 (ITR1).

010: Internal Trigger 2 (ITR2).

011: Internal Trigger 3 (ITR3). reserved

100: TI1 Edge Detector (TI1F ED)

101: Filtered Timer Input 1 (TI1FP1)

110: Filtered Timer Input 2 (TI2FP2)

111: External Trigger input (ETRF)

See *Table 125: TIMx internal trigger connection on page 652* for more details on ITRx meaning for each Timer.

Note: These bits must be changed only when they are not used (e.g. when SMS=000) to avoid wrong edge detections at the transition.

#### Bit 3 OCCS: OCREF clear selection

This bit is used to select the OCREF clear source

0: OCREF CLR INT is connected to the OCREF CLR input

1: OCREF CLR INT is connected to ETRF

#### Bits 2:0 SMS: Slave mode selection

When external signals are selected the active edge of the trigger signal (TRGI) is linked to the polarity selected on the external input (see Input Control register and Control Register description.

0000: Slave mode disabled - if CEN = '1 then the prescaler is clocked directly by the internal clock.

0001: Encoder mode 1 - Counter counts up/down on TI1FP1 edge depending on TI2FP2 level.

0010: Encoder mode 2 - Counter counts up/down on TI2FP2 edge depending on TI1FP1 level.

0011: Encoder mode 3 - Counter counts up/down on both TI1FP1 and TI2FP2 edges depending on the level of the other input.

0100: Reset Mode - Rising edge of the selected trigger input (TRGI) reinitializes the counter and generates an update of the registers.

0101: Gated Mode - The counter clock is enabled when the trigger input (TRGI) is high. The counter stops (but is not reset) as soon as the trigger becomes low. Both start and stop of the counter are controlled.

0110: Trigger Mode - The counter starts at a rising edge of the trigger TRGI (but it is not reset). Only the start of the counter is controlled.

0111: External Clock Mode 1 - Rising edges of the selected trigger (TRGI) clock the counter.

1000: Combined reset + trigger mode - Rising edge of the selected trigger input (TRGI) reinitializes the counter, generates an update of the registers and starts the counter.

Note: The gated mode must not be used if TI1F\_ED is selected as the trigger input (TS=100). Indeed, TI1F\_ED outputs 1 pulse for each transition on TI1F, whereas the gated mode checks the level of the trigger signal.

Note: The clock of the slave timer must be enabled prior to receive events from the master timer, and must not be changed on-the-fly while triggers are received from the master timer

## Table 125. TIMx internal trigger connection

| Slave TIM | ITR0 (TS = 000) | ITR1 (TS = 001) | ITR2 (TS = 010) | ITR3 (TS = 011) |
|-----------|-----------------|-----------------|-----------------|-----------------|
| TIM2      | TIM1            | TIM8            | TIM3            | TIM4            |





# Table 125. TIMx internal trigger connection (continued)

| Slave TIM | ITR0 (TS = 000) | ITR1 (TS = 001) | ITR2 (TS = 010) | ITR3 (TS = 011) |
|-----------|-----------------|-----------------|-----------------|-----------------|
| TIM3      | TIM1            | TIM2            | TIM5            | TIM4            |
| TIM4      | TIM1            | TIM2            | TIM3            | TIM8            |

# 21.4.4 TIMx DMA/Interrupt enable register (TIMx\_DIER)

Address offset: 0x0C Reset value: 0x0000

| 15   | 14  | 13   | 12    | 11    | 10    | 9     | 8   | 1    | 6   | 5    | 4     | 3     | 2     | 1     | 0   |
|------|-----|------|-------|-------|-------|-------|-----|------|-----|------|-------|-------|-------|-------|-----|
| Res. | TDE | Res. | CC4DE | CC3DE | CC2DE | CC1DE | UDE | Res. | TIE | Res. | CC4IE | CC3IE | CC2IE | CC1IE | UIE |
|      | rw  |      | rw    | rw    | rw    | rw    | rw  |      | rw  |      | rw    | rw    | rw    | rw    | rw  |

Bit 15 Reserved, must be kept at reset value.

Bit 14 TDE: Trigger DMA request enable

0: Trigger DMA request disabled.

1: Trigger DMA request enabled.

Bit 13 Reserved, must be kept at reset value.

Bit 12 CC4DE: Capture/Compare 4 DMA request enable

0: CC4 DMA request disabled.

1: CC4 DMA request enabled.

Bit 11 CC3DE: Capture/Compare 3 DMA request enable

0: CC3 DMA request disabled.

1: CC3 DMA request enabled.

Bit 10 CC2DE: Capture/Compare 2 DMA request enable

0: CC2 DMA request disabled.

1: CC2 DMA request enabled.

Bit 9 CC1DE: Capture/Compare 1 DMA request enable

0: CC1 DMA request disabled.

1: CC1 DMA request enabled.

Bit 8 **UDE**: Update DMA request enable

0: Update DMA request disabled.

1: Update DMA request enabled.

Bit 7 Reserved, must be kept at reset value.

Bit 6 TIE: Trigger interrupt enable

0: Trigger interrupt disabled.

1: Trigger interrupt enabled.

Bit 5 Reserved, must be kept at reset value.

Bit 4 **CC4IE**: Capture/Compare 4 interrupt enable

0: CC4 interrupt disabled.

1: CC4 interrupt enabled.

Bit 3 CC3IE: Capture/Compare 3 interrupt enable

0: CC3 interrupt disabled.

1: CC3 interrupt enabled.



Bit 2 CC2IE: Capture/Compare 2 interrupt enable

0: CC2 interrupt disabled.

1: CC2 interrupt enabled.

Bit 1 **CC1IE**: Capture/Compare 1 interrupt enable

0: CC1 interrupt disabled.

1: CC1 interrupt enabled.

Bit 0 **UIE**: Update interrupt enable

0: Update interrupt disabled.

1: Update interrupt enabled.

# 21.4.5 TIMx status register (TIMx\_SR)

Address offset: 0x10 Reset value: 0x0000

| 1  | 5   | 14   | 13   | 12    | 11    | 10    | 9     | 8    | 7    | 6     | 5    | 4     | 3     | 2     | 1     | 0     |
|----|-----|------|------|-------|-------|-------|-------|------|------|-------|------|-------|-------|-------|-------|-------|
| Re | es. | Res. | Res. | CC4OF | CC3OF | CC2OF | CC10F | Res. | Res. | TIF   | Res. | CC4IF | CC3IF | CC2IF | CC1IF | UIF   |
|    |     |      |      | rc_w0 | rc_w0 | rc_w0 | rc_w0 |      |      | rc_w0 |      | rc_w0 | rc_w0 | rc_w0 | rc_w0 | rc_w0 |

Bits 15:13 Reserved, must be kept at reset value.

Bit 12 CC4OF: Capture/Compare 4 overcapture flag

refer to CC1OF description

Bit 11 CC3OF: Capture/Compare 3 overcapture flag

refer to CC1OF description

Bit 10 CC2OF: Capture/compare 2 overcapture flag

refer to CC1OF description

Bit 9 CC10F: Capture/Compare 1 overcapture flag

This flag is set by hardware only when the corresponding channel is configured in input capture mode. It is cleared by software by writing it to '0'.

0: No overcapture has been detected.

1: The counter value has been captured in TIMx\_CCR1 register while CC1IF flag was already set

Bits 8:7 Reserved, must be kept at reset value.

Bit 6 TIF: Trigger interrupt flag

This flag is set by hardware on trigger event (active edge detected on TRGI input when the slave mode controller is enabled in all modes but gated mode. It is set when the counter starts or stops when gated mode is selected. It is cleared by software.

0: No trigger event occurred.

1: Trigger interrupt pending.

Bit 5 Reserved, must be kept at reset value.

Bit 4 CC4IF: Capture/Compare 4 interrupt flag

Refer to CC1IF description

Bit 3 CC3IF: Capture/Compare 3 interrupt flag

Refer to CC1IF description



Bit 2 CC2IF: Capture/Compare 2 interrupt flag

Refer to CC1IF description

Bit 1 CC1IF: Capture/compare 1 interrupt flag

If channel CC1 is configured as output: This flag is set by hardware when the counter matches the compare value, with some exception in center-aligned mode (refer to the CMS bits in the TIMx\_CR1 register description) and in retriggerable one pulse mode. It is cleared by software.

0: No match.

1: The content of the counter TIMx\_CNT has matched the content of the TIMx\_CCR1 register.

**If channel CC1 is configured as input**: This bit is set by hardware on a capture. It is cleared by software or by reading the TIMx\_CCR1 register.

0: No input capture occurred.

1: The counter value has been captured in TIMx\_CCR1 register (An edge has been detected on IC1 which matches the selected polarity).

## Bit 0 **UIF**: Update interrupt flag

This bit is set by hardware on an update event. It is cleared by software.

0: No update occurred

1: Update interrupt pending. This bit is set by hardware when the registers are updated:

At overflow or underflow (for TIM2 to TIM4) and if UDIS=0 in the TIMx\_CR1 register.

When CNT is reinitialized by software using the UG bit in TIMx\_EGR register, if URS=0 and UDIS=0 in the TIMx\_CR1 register.

When CNT is reinitialized by a trigger event (refer to the synchro control register description), if URS=0 and UDIS=0 in the TIMx CR1 register.

# 21.4.6 TIMx event generation register (TIMx\_EGR)

Address offset: 0x14 Reset value: 0x0000

| 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6  | 5    | 4    | 3    | 2    | 1    | 0  |
|------|------|------|------|------|------|------|------|------|----|------|------|------|------|------|----|
| Res. | TG | Res. | CC4G | CC3G | CC2G | CC1G | UG |
|      |      |      |      |      |      |      |      |      | w  |      | w    | w    | w    | w    | w  |

Bits 15:7 Reserved, must be kept at reset value.

Bit 6 TG: Trigger generation

This bit is set by software in order to generate an event, it is automatically cleared by hardware.

0: No action

1: The TIF flag is set in TIMx\_SR register. Related interrupt or DMA transfer can occur if enabled.

Bit 5 Reserved, must be kept at reset value.

Bit 4 CC4G: Capture/compare 4 generation

Refer to CC1G description

Bit 3 **CC3G**: Capture/compare 3 generation

Refer to CC1G description



# Bit 2 CC2G: Capture/compare 2 generation

Refer to CC1G description

### Bit 1 **CC1G**: Capture/compare 1 generation

This bit is set by software in order to generate an event, it is automatically cleared by hardware.

0: No action

1: A capture/compare event is generated on channel 1:

## If channel CC1 is configured as output:

CC1IF flag is set, Corresponding interrupt or DMA request is sent if enabled.

#### If channel CC1 is configured as input:

The current value of the counter is captured in TIMx\_CCR1 register. The CC1IF flag is set, the corresponding interrupt or DMA request is sent if enabled. The CC1OF flag is set if the CC1IF flag was already high.

### Bit 0 **UG**: Update generation

This bit can be set by software, it is automatically cleared by hardware.

0: No action

1: Re-initialize the counter and generates an update of the registers. Note that the prescaler counter is cleared too (anyway the prescaler ratio is not affected). The counter is cleared if the center-aligned mode is selected or if DIR=0 (upcounting), else it takes the auto-reload value (TIMx\_ARR) if DIR=1 (downcounting).

# 21.4.7 TIMx capture/compare mode register 1 (TIMx CCMR1)

Address offset: 0x18 Reset value: 0x0000

The channels can be used in input (capture mode) or in output (compare mode). The direction of a channel is defined by configuring the corresponding CCxS bits. All the other bits of this register have a different function in input and in output mode. For a given bit, OCxx describes its function when the channel is configured in output, ICxx describes its function when the channel is configured in input. So you must take care that the same bit can have a different meaning for the input stage and for the output stage.

| 31    | 30   | 29       | 28   | 27    | 26      | 25   | 24          | 23    | 22   | 21       | 20   | 19    | 18      | 17   | 16          |
|-------|------|----------|------|-------|---------|------|-------------|-------|------|----------|------|-------|---------|------|-------------|
| Res.  | Res. | Res.     | Res. | Res.  | Res.    | Res. | OC2M<br>[3] | Res.  | Res. | Res.     | Res. | Res.  | Res.    | Res. | OC1M<br>[3] |
|       |      |          |      |       |         |      | Res.        |       |      |          |      |       |         |      | Res.        |
|       |      |          |      |       |         |      | rw          |       |      |          |      |       |         |      | rw          |
| 15    | 14   | 13       | 12   | 11    | 10      | 9    | 8           | 7     | 6    | 5        | 4    | 3     | 2       | 1    | 0           |
| OC2CE | (    | OC2M[2:0 | )]   | OC2PE | OC2FE   | CCO  | S[1:0]      | OC1CE | (    | OC1M[2:0 | )]   | OC1PE | OC1FE   | CC19 | S[1:0]      |
|       | IC2F | [3:0]    |      | IC2PS | SC[1:0] | 002  | S[1.0]      |       | IC1F | [3:0]    |      | IC1PS | SC[1:0] | CCI  | [U.1]G      |
| rw    | rw   | rw       | rw   | rw    | rw      | rw   | rw          | rw    | rw   | rw       | rw   | rw    | rw      | rw   | rw          |

# **Output compare mode**

Bits 31:25 Reserved, always read as 0.

Bit 24 OC2M[3]: Output Compare 2 mode - bit 3

Bits 23:17 Reserved, always read as 0.

Bit 16 OC1M[3]: Output Compare 1 mode - bit 3

Bit 15 OC2CE: Output compare 2 clear enable

656/1141 DocID022558 Rev 8



Bits 14:12 OC2M[2:0]: Output compare 2 mode

refer to OC1M description on bits 6:4

Bit 11 OC2PE: Output compare 2 preload enable

Bit 10 OC2FE: Output compare 2 fast enable

Bits 9:8 CC2S[1:0]: Capture/Compare 2 selection

This bit-field defines the direction of the channel (input/output) as well as the used input.

00: CC2 channel is configured as output

01: CC2 channel is configured as input, IC2 is mapped on TI2

10: CC2 channel is configured as input, IC2 is mapped on TI1

11: CC2 channel is configured as input, IC2 is mapped on TRC. This mode is working only if an internal trigger input is selected through the TS bit (TIMx\_SMCR register)

Note: CC2S bits are writable only when the channel is OFF (CC2E = 0 in TIMx\_CCER).

Bit 7 OC1CE: Output compare 1 clear enable

0: OC1Ref is not affected by the ETRF input

1: OC1Ref is cleared as soon as a High level is detected on ETRF input



### Bits 6:4 OC1M: Output compare 1 mode

These bits define the behavior of the output reference signal OC1REF from which OC1 and OC1N are derived. OC1REF is active high whereas OC1 and OC1N active level depends on CC1P and CC1NP bits.

0000: Frozen - The comparison between the output compare register TIMx\_CCR1 and the counter TIMx\_CNT has no effect on the outputs.(this mode is used to generate a timing base).

0001: Set channel 1 to active level on match. OC1REF signal is forced high when the counter TIMx CNT matches the capture/compare register 1 (TIMx CCR1).

0010: Set channel 1 to inactive level on match. OC1REF signal is forced low when the counter TIMx\_CNT matches the capture/compare register 1 (TIMx\_CCR1).

0011: Toggle - OC1REF toggles when TIMx\_CNT=TIMx\_CCR1.

0100: Force inactive level - OC1REF is forced low.

0101: Force active level - OC1REF is forced high.

0110: PWM mode 1 - In upcounting, channel 1 is active as long as TIMx\_CNT<TIMx\_CCR1 else inactive. In downcounting, channel 1 is inactive (OC1REF='0) as long as TIMx\_CNT>TIMx\_CCR1 else active (OC1REF=1).

0111: PWM mode 2 - In upcounting, channel 1 is inactive as long as

TIMx\_CNT<TIMx\_CCR1 else active. In downcounting, channel 1 is active as long as TIMx\_CNT>TIMx\_CCR1 else inactive.

1000: Retriggerable OPM mode 1 - In up-counting mode, the channel is active until a trigger event is detected (on TRGI signal). Then, a comparison is performed as in PWM mode 1 and the channels becomes inactive again at the next update. In down-counting mode, the channel is inactive until a trigger event is detected (on TRGI signal). Then, a comparison is performed as in PWM mode 1 and the channels becomes inactive again at the next update.

1001: Retriggerable OPM mode 2 - In up-counting mode, the channel is inactive until a trigger event is detected (on TRGI signal). Then, a comparison is performed as in PWM mode 2 and the channels becomes inactive again at the next update. In down-counting mode, the channel is active until a trigger event is detected (on TRGI signal). Then, a comparison is performed as in PWM mode 1 and the channels becomes active again at the next update.

1010: Reserved,

1011: Reserved.

1100: Combined PWM mode 1 - OC1REF has the same behavior as in PWM mode 1. OC1REFC is the logical OR between OC1REF and OC2REF.

1101: Combined PWM mode 2 - OC1REF has the same behavior as in PWM mode 2. OC1REFC is the logical AND between OC1REF and OC2REF.

1110: Asymmetric PWM mode 1 - OC1REF has the same behavior as in PWM mode 1. OC1REFC outputs OC1REF when the counter is counting up, OC2REF when it is counting down.

1111: Asymmetric PWM mode 2 - OC1REF has the same behavior as in PWM mode 2. OC1REFC outputs OC1REF when the counter is counting up, OC2REF when it is counting down.

Note: 1: These bits can not be modified as long as LOCK level 3 has been programmed (LOCK bits in TIMx\_BDTR register) and CC1S=00 (the channel is configured in output).

**2:** In PWM mode, the OCREF level changes only when the result of the comparison changes or when the output compare mode switches from "frozen" mode to "PWM" mode.

577

# Bit 3 OC1PE: Output compare 1 preload enable

- 0: Preload register on TIMx\_CCR1 disabled. TIMx\_CCR1 can be written at anytime, the new value is taken in account immediately.
- 1: Preload register on TIMx\_CCR1 enabled. Read/Write operations access the preload register. TIMx\_CCR1 preload value is loaded in the active register at each update event.
- Note: 1: These bits can not be modified as long as LOCK level 3 has been programmed (LOCK bits in TIMx\_BDTR register) and CC1S=00 (the channel is configured in output).
  - **2:** The PWM mode can be used without validating the preload register only in one-pulse mode (OPM bit set in TIMx\_CR1 register). Else the behavior is not guaranteed.

# Bit 2 OC1FE: Output compare 1 fast enable

This bit is used to accelerate the effect of an event on the trigger in input on the CC output. 0: CC1 behaves normally depending on counter and CCR1 values even when the trigger is ON. The minimum delay to activate CC1 output when an edge occurs on the trigger input is 5 clock cycles.

1: An active edge on the trigger input acts like a compare match on CC1 output. Then, OC is set to the compare level independently from the result of the comparison. Delay to sample the trigger input and to activate CC1 output is reduced to 3 clock cycles. OCFE acts only if the channel is configured in PWM1 or PWM2 mode.

### Bits 1:0 CC1S: Capture/Compare 1 selection

This bit-field defines the direction of the channel (input/output) as well as the used input.

00: CC1 channel is configured as output.

01: CC1 channel is configured as input, IC1 is mapped on TI1.

10: CC1 channel is configured as input, IC1 is mapped on TI2.

11: CC1 channel is configured as input, IC1 is mapped on TRC. This mode is working only if an internal trigger input is selected through TS bit (TIMx SMCR register)

Note: CC1S bits are writable only when the channel is OFF (CC1E = 0 in TIMx\_CCER).

## Input capture mode

- Bits 31:16 Reserved, always read as 0.
- Bits 15:12 IC2F: Input capture 2 filter
- Bits 11:10 IC2PSC[1:0]: Input capture 2 prescaler
  - Bits 9:8 CC2S: Capture/compare 2 selection

This bit-field defines the direction of the channel (input/output) as well as the used input.

00: CC2 channel is configured as output.

01: CC2 channel is configured as input, IC2 is mapped on TI2.

10: CC2 channel is configured as input, IC2 is mapped on TI1.

11: CC2 channel is configured as input, IC2 is mapped on TRC. This mode is working only if an internal trigger input is selected through TS bit (TIMx\_SMCR register)

Note: CC2S bits are writable only when the channel is OFF (CC2E = 0 in TIMx\_CCER).



# Bits 7:4 IC1F: Input capture 1 filter

This bit-field defines the frequency used to sample TI1 input and the length of the digital filter applied to TI1. The digital filter is made of an event counter in which N consecutive events are needed to validate a transition on the output:

0000: No filter, sampling is done at f<sub>DTS</sub>

0001: f<sub>SAMPLING</sub>=f<sub>CK INT</sub>, N=2

0010: f<sub>SAMPLING</sub>=f<sub>CK INT</sub>, N=4

0011: f<sub>SAMPLING</sub>=f<sub>CK INT</sub>, N=8

0100: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/2, N=6

0101: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/2, N=8

0110: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/4, N=6

0111:  $f_{SAMPLING} = f_{DTS}/4$ , N=8

1000:  $f_{SAMPLING} = f_{DTS}/8$ , N=6

1001: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/8, N=8

1010:  $f_{SAMPLING} = f_{DTS}/16$ , N=5

1011: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/16, N=6

1100: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/16, N=8

1101: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/32, N=5

1110: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/32, N=6

1111:  $f_{SAMPLING} = f_{DTS}/32$ , N=8

# Bits 3:2 IC1PSC: Input capture 1 prescaler

This bit-field defines the ratio of the prescaler acting on CC1 input (IC1). The prescaler is reset as soon as CC1E=0 (TIMx CCER register).

00: no prescaler, capture is done each time an edge is detected on the capture input

01: capture is done once every 2 events

10: capture is done once every 4 events

11: capture is done once every 8 events

# Bits 1:0 CC1S: Capture/Compare 1 selection

This bit-field defines the direction of the channel (input/output) as well as the used input.

00: CC1 channel is configured as output

01: CC1 channel is configured as input, IC1 is mapped on TI1

10: CC1 channel is configured as input, IC1 is mapped on TI2

11: CC1 channel is configured as input, IC1 is mapped on TRC. This mode is working only if an internal trigger input is selected through TS bit (TIMx\_SMCR register)

Note: CC1S bits are writable only when the channel is OFF (CC1E = 0 in TIMx\_CCER).

# 21.4.8 TIMx capture/compare mode register 2 (TIMx\_CCMR2)

Address offset: 0x1C Reset value: 0x0000

Refer to the above CCMR1 register description.

| 31    | 30   | 29       | 28   | 27    | 26      | 25   | 24          | 23    | 22   | 21       | 20   | 19    | 18      | 17   | 16          |
|-------|------|----------|------|-------|---------|------|-------------|-------|------|----------|------|-------|---------|------|-------------|
| Res.  | Res. | Res.     | Res. | Res.  | Res.    | Res. | OC4M<br>[3] | Res.  | Res. | Res.     | Res. | Res.  | Res.    | Res. | OC3M<br>[3] |
|       |      |          |      |       |         |      | Res.        |       |      |          |      |       |         |      | Res.        |
|       |      |          |      |       |         |      | rw          |       |      |          |      |       |         |      | rw          |
| 15    | 14   | 13       | 12   | 11    | 10      | 9    | 8           | 7     | 6    | 5        | 4    | 3     | 2       | 1    | 0           |
| OC4CE | (    | OC4M[2:0 | )]   | OC4PE | OC4FE   | CCA  | 014-01      | OC3CE | (    | OC3M[2:0 | )]   | OC3PE | OC3FE   | CC3  | 2[1:0]      |
|       | IC4F | [3:0]    |      | IC4PS | SC[1:0] | 004  | S[1:0]      |       | IC3F | [3:0]    |      | IC3PS | SC[1:0] | CC3  | 5[1.0]      |
| rw    | rw   | rw       | rw   | rw    | rw      | rw   | rw          | rw    | rw   | rw       | rw   | rw    | rw      | rw   | rw          |



# **Output compare mode**

- Bits 31:25 Reserved, always read as 0.
  - Bit 24 OC4M[3]: Output Compare 2 mode bit 3
- Bits 23:17 Reserved, always read as 0.
  - Bit 16 OC3M[3]: Output Compare 1 mode bit 3
  - Bit 15 OC4CE: Output compare 4 clear enable
- Bits 14:12 **OC4M**: Output compare 4 mode

Refer to OC1M description (bits 6:4 in TIMx CCMR1 register)

- Bit 11 OC4PE: Output compare 4 preload enable
- Bit 10 OC4FE: Output compare 4 fast enable
- Bits 9:8 CC4S: Capture/Compare 4 selection

This bit-field defines the direction of the channel (input/output) as well as the used input.

- 00: CC4 channel is configured as output
- 01: CC4 channel is configured as input, IC4 is mapped on TI4
- 10: CC4 channel is configured as input, IC4 is mapped on TI3
- 11: CC4 channel is configured as input, IC4 is mapped on TRC. This mode is working only if an internal trigger input is selected through TS bit (TIMx SMCR register)

Note: CC4S bits are writable only when the channel is OFF (CC4E = 0 in TIMx\_CCER).

- Bit 7 OC3CE: Output compare 3 clear enable
- Bits 6:4 OC3M: Output compare 3 mode

Refer to OC1M description (bits 6:4 in TIMx\_CCMR1 register)

- Bit 3 OC3PE: Output compare 3 preload enable
- Bit 2 OC3FE: Output compare 3 fast enable
- Bits 1:0 CC3S: Capture/Compare 3 selection

This bit-field defines the direction of the channel (input/output) as well as the used input.

- 00: CC3 channel is configured as output
- 01: CC3 channel is configured as input, IC3 is mapped on TI3
- 10: CC3 channel is configured as input, IC3 is mapped on TI4
- 11: CC3 channel is configured as input, IC3 is mapped on TRC. This mode is working only if an internal trigger input is selected through TS bit (TIMx\_SMCR register)

Note: CC3S bits are writable only when the channel is OFF (CC3E = 0 in TIMx\_CCER).

## Input capture mode

- Bits 31:16 Reserved, always read as 0.
- Bits 15:12 IC4F: Input capture 4 filter
- Bits 11:10 IC4PSC: Input capture 4 prescaler
  - Bits 9:8 CC4S: Capture/Compare 4 selection

This bit-field defines the direction of the channel (input/output) as well as the used input.

- 00: CC4 channel is configured as output
- 01: CC4 channel is configured as input, IC4 is mapped on TI4
- 10: CC4 channel is configured as input, IC4 is mapped on TI3
- 11: CC4 channel is configured as input, IC4 is mapped on TRC. This mode is working only if an internal trigger input is selected through TS bit (TIMx SMCR register)

Note: CC4S bits are writable only when the channel is OFF (CC4E = 0 in TIMx\_CCER).



Bits 7:4 IC3F: Input capture 3 filter

Bits 3:2 IC3PSC: Input capture 3 prescaler

Bits 1:0 CC3S: Capture/Compare 3 selection

This bit-field defines the direction of the channel (input/output) as well as the used input.

00: CC3 channel is configured as output

01: CC3 channel is configured as input, IC3 is mapped on TI3

10: CC3 channel is configured as input, IC3 is mapped on TI4

11: CC3 channel is configured as input, IC3 is mapped on TRC. This mode is working only if an internal trigger input is selected through TS bit (TIMx SMCR register)

Note: CC3S bits are writable only when the channel is OFF (CC3E = 0 in TIMx CCER).

# 21.4.9 TIMx capture/compare enable register (TIMx\_CCER)

Address offset: 0x20 Reset value: 0x0000

| 15  | 5  | 14   | 13   | 12   | 11    | 10   | 9    | 8    | 7     | 6    | 5    | 4    | 3     | 2    | 1    | 0    |
|-----|----|------|------|------|-------|------|------|------|-------|------|------|------|-------|------|------|------|
| CC4 | NP | Res. | CC4P | CC4E | CC3NP | Res. | CC3P | CC3E | CC2NP | Res. | CC2P | CC2E | CC1NP | Res. | CC1P | CC1E |
| rv  | ′  |      | rw   | rw   | rw    |      | rw   | rw   | rw    |      | rw   | rw   | rw    |      | rw   | rw   |

Bit 15 CC4NP: Capture/Compare 4 output Polarity.

Refer to CC1NP description

Bit 14 Reserved, must be kept at reset value.

Bit 13 **CC4P**: Capture/Compare 4 output Polarity.

Refer to CC1P description

Bit 12 **CC4E**: Capture/Compare 4 output enable. refer to CC1E description

Bit 11 **CC3NP**: Capture/Compare 3 output Polarity.

Refer to CC1NP description

Bit 10 Reserved, must be kept at reset value.

Bit 9 **CC3P**: Capture/Compare 3 output Polarity.

Refer to CC1P description

Bit 8 **CC3E**: Capture/Compare 3 output enable.

Refer to CC1E description

Bit 7 **CC2NP**: Capture/Compare 2 output Polarity.

Refer to CC1NP description

Bit 6 Reserved, must be kept at reset value.

Bit 5 **CC2P**: Capture/Compare 2 output Polarity. refer to CC1P description

Bit 4 **CC2E**: Capture/Compare 2 output enable.

Refer to CC1E description

Bit 3 CC1NP: Capture/Compare 1 output Polarity.

**CC1 channel configured as output**: CC1NP must be kept cleared in this case. **CC1 channel configured as input**: This bit is used in conjunction with CC1P to define TI1FP1/TI2FP1 polarity. refer to CC1P description.

662/1141 DocID022558 Rev 8



Bit 2 Reserved, must be kept at reset value.

Bit 1 CC1P: Capture/Compare 1 output Polarity.

## CC1 channel configured as output:

0: OC1 active high 1: OC1 active low

**CC1 channel configured as input**: CC1NP/CC1P bits select TI1FP1 and TI2FP1 polarity for trigger or capture operations.

00: noninverted/rising edge

Circuit is sensitive to TIxFP1 rising edge (capture, trigger in reset, external clock or trigger mode), TIxFP1 is not inverted (trigger in gated mode, encoder mode).

01: inverted/falling edge

Circuit is sensitive to TIxFP1 falling edge (capture, trigger in reset, external clock or trigger mode), TIxFP1 is inverted (trigger in gated mode, encoder mode).

10: reserved, do not use this configuration.

11: noninverted/both edges

Circuit is sensitive to both TIxFP1 rising and falling edges (capture, trigger in reset, external clock or trigger mode), TIxFP1 is not inverted (trigger in gated mode). This configuration must not be used for encoder mode.

# Bit 0 CC1E: Capture/Compare 1 output | December 2 | Decem

CC1 channel configured as out

0: Off - OC1 is not active

1: On - OC1 signal is output on the corresponding output pin

**CC1 channel configured as input**: This bit determines if a capture of the counter value can actually be done into the input capture/compare register 1 (TIMx CCR1) or not.

0: Capture disabled

1: Capture enabled

Table 126. Output control bit for standard OCx channels

| CCxE bit | OCx output state                  |
|----------|-----------------------------------|
| 0        | Output Disabled (OCx=0, OCx_EN=0) |
| 1        | OCx=OCxREF + Polarity, OCx_EN=1   |

Note: The state of the external IO pins connected to the standard OCx channels depends on the OCx channel state and the GPIO and AFIO registers.

# 21.4.10 TIMx counter (TIMx\_CNT)

Address offset: 0x24 Reset value: 0x0000

| 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24        | 23        | 22         | 21   | 20 | 19 | 18 | 1/ | 16 |
|-------------------------|----|----|----|----|----|----|-----------|-----------|------------|------|----|----|----|----|----|
| CNT[31]<br>or<br>UIFCPY |    |    |    |    |    | CN | IT[30:16] | (dependii | ng on time | ers) |    |    |    |    |    |
| rw or r                 | rw        | rw        | rw         | rw   | rw | rw | rw | rw | rw |
| 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8         | 7         | 6          | 5    | 4  | 3  | 2  | 1  | 0  |
|                         |    |    |    |    |    |    | CNT[      | 15:0]     |            |      |    |    |    |    |    |
| rw                      | rw | rw | rw | rw | rw | rw | rw        | rw        | rw         | rw   | rw | rw | rw | rw | rw |



Bit 31 Value depends on IUFREMAP in TIMx\_CR1.

If UIFREMAP = 0

CNT[31]: Most significant bit of counter value (on TIM2)

Reserved on other timers

If UIFREMAP = 1
UIFCPY: UIF Copy

This bit is a read-only copy of the UIF bit of the TIMx ISR register

Bits 30:16 CNT[30:16]: Most significant part counter value (on TIM2)

Bits 15:0 CNT[15:0]: Least significant part of counter value

# 21.4.11 TIMx prescaler (TIMx\_PSC)

Address offset: 0x28 Reset value: 0x0000

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|-----|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | PSC | [15:0] |    |    |    |    |    |    |    |
| rw  | rw     | rw | rw | rw | rw | rw | rw | rw |

Bits 15:0 PSC[15:0]: Prescaler value

The counter clock frequency CK\_CNT is equal to  $f_{CK\ PSC}$  / (PSC[15:0] + 1).

PSC contains the value to be loaded in the active prescaler register at each update event (including when the counter is cleared through UG bit of TIMx\_EGR register or through trigger controller when configured in "reset mode").

# 21.4.12 TIMx auto-reload register (TIMx\_ARR)

Address offset: 0x2C

Reset value: 0xFFFF FFFF

| 01 | 00 | 20 | 20 | 21 | 20 | 20     | 27        | 20        | ~~      | 21 | 20 | 10 | 10 | ., | 10 |
|----|----|----|----|----|----|--------|-----------|-----------|---------|----|----|----|----|----|----|
|    | _  | _  |    |    |    | ARR[31 | :16] (dep | ending or | timers) | _  |    | _  |    |    |    |
| rw     | rw        | rw        | rw      | rw | rw | rw | rw | rw | rw |
| 15 | 14 | 13 | 12 | 11 | 10 | 9      | 8         | 7         | 6       | 5  | 4  | 3  | 2  | 1  | 0  |
|    | _  | _  |    |    |    | _      | ARR       | [15:0]    |         | _  |    | _  |    |    |    |
| rw     | rw        | rw        | rw      | rw | rw | rw | rw | rw | rw |

Bits 31:16 ARR[31:16]: High auto-reload value (on TIM2)

Bits 15:0 ARR[15:0]: Low Auto-reload Prescaler value

ARR is the value to be loaded in the actual auto-reload register.

Refer to the Section 21.3.1: Time-base unit on page 603 for more details about ARR update and behavior.

The counter is blocked while the auto-reload value is null.

577

# 21.4.13 TIMx capture/compare register 1 (TIMx\_CCR1)

Address offset: 0x34 Reset value: 0x0000

| 31   | 30   | 29   | 28   | 27   | 26   | 25    | 24         | 23       | 22         | 21   | 20   | 19   | 18   | 17   | 16   |
|------|------|------|------|------|------|-------|------------|----------|------------|------|------|------|------|------|------|
|      |      |      |      |      |      | CCR1[ | 31:16] (de | epending | on timers) | )    |      |      |      |      |      |
| rw/r  | rw/r       | rw/r     | rw/r       | rw/r | rw/r | rw/r | rw/r | rw/r | rw/r |
| 15   | 14   | 13   | 12   | 11   | 10   | 9     | 8          | 7        | 6          | 5    | 4    | 3    | 2    | 1    | 0    |
|      |      |      |      |      |      |       | CCF        | R1[15:0] |            |      |      |      |      |      |      |
| rw/r  | rw/r       | rw/r     | rw/r       | rw/r | rw/r | rw/r | rw/r | rw/r | rw/r |

Bits 31:16 CCR1[31:16]: High Capture/Compare 1 value (on TIM2 and TIM5)

Bits 15:0 CCR1[15:0]: Low Capture/Compare 1 value

### If channel CC1 is configured as output:

CCR1 is the value to be loaded in the actual capture/compare 1 register (preload value). It is loaded permanently if the preload feature is not selected in the TIMx\_CCMR1 register (bit OC1PE). Else the preload value is copied in the active capture/compare 1 register when an update event occurs.

The active capture/compare register contains the value to be compared to the counter TIMx\_CNT and signaled on OC1 output.

### If channel CC1is configured as input:

CCR1 is the counter value transferred by the last input capture 1 event (IC1). The TIMX CCR1 register is read-only and cannot be programmed.

# 21.4.14 TIMx capture/compare register 2 (TIMx\_CCR2)

Address offset: 0x38

Reset value: 0x00000000

| 31   | 30   | 29   | 28   | 27   | 26   | 25     | 24         | 23       | 22        | 21   | 20   | 19   | 18   | 17   | 16   |
|------|------|------|------|------|------|--------|------------|----------|-----------|------|------|------|------|------|------|
|      | _    | _    |      |      |      | CCR2[3 | 1:16] (dep | ending o | n timers) |      | _    |      |      |      |      |
| rw/r   | rw/r       | rw/r     | rw/r      | rw/r | rw/r | rw/r | rw/r | rw/r | rw/r |
| 15   | 14   | 13   | 12   | 11   | 10   | 9      | 8          | 7        | 6         | 5    | 4    | 3    | 2    | 1    | 0    |
|      | _    | _    |      |      |      |        | CCR2       | [15:0]   |           |      | _    |      |      |      |      |
| rw/r   | rw/r       | rw/r     | rw/r      | rw/r | rw/r | rw/r | rw/r | rw/r | rw/r |

Bits 31:16 CCR2[31:16]: High Capture/Compare 2 value (on TIM2 and TIM5)

Bits 15:0 CCR2[15:0]: Low Capture/Compare 2 value

## If channel CC2 is configured as output:

CCR2 is the value to be loaded in the actual capture/compare 2 register (preload value). It is loaded permanently if the preload feature is not selected in the TIMx\_CCMR1 register (bit OC2PE). Else the preload value is copied in the active capture/compare 2 register when an update event occurs.

The active capture/compare register contains the value to be compared to the counter TIMx\_CNT and signalled on OC2 output.

### If channel CC2 is configured as input:

CCR2 is the counter value transferred by the last input capture 2 event (IC2). The TIMx CCR2 register is read-only and cannot be programmed.



# 21.4.15 TIMx capture/compare register 3 (TIMx\_CCR3)

Address offset: 0x3C Reset value: 0x0000

| 31   | 30   | 29   | 28   | 27   | 26   | 25    | 24         | 23       | 22         | 21   | 20   | 19   | 18   | 17   | 16   |
|------|------|------|------|------|------|-------|------------|----------|------------|------|------|------|------|------|------|
|      |      |      |      |      |      | CCR3[ | 31:16] (de | epending | on timers) | )    |      |      |      |      |      |
| rw/r  | rw/r       | rw/r     | rw/r       | rw/r | rw/r | rw/r | rw/r | rw/r | rw/r |
| 15   | 14   | 13   | 12   | 11   | 10   | 9     | 8          | 7        | 6          | 5    | 4    | 3    | 2    | 1    | 0    |
|      |      |      |      |      |      |       | CCF        | 3[15:0]  |            |      |      |      |      |      |      |
| rw/r  | rw/r       | rw/r     | rw/r       | rw/r | rw/r | rw/r | rw/r | rw/r | rw/r |

Bits 31:16 CCR3[31:16]: High Capture/Compare 3 value (on TIM2 and TIM5)

Bits 15:0 CCR3[15:0]: Low Capture/Compare value

### If channel CC3 is configured as output:

CCR3 is the value to be loaded in the actual capture/compare 3 register (preload value). It is loaded permanently if the preload feature is not selected in the TIMx\_CCMR2 register (bit OC3PE). Else the preload value is copied in the active capture/compare 3 register when an update event occurs.

The active capture/compare register contains the value to be compared to the counter TIMx\_CNT and signalled on OC3 output.

## If channel CC3is configured as input:

CCR3 is the counter value transferred by the last input capture 3 event (IC3). The TIMx\_CCR3 register is read-only and cannot be programmed.

# 21.4.16 TIMx capture/compare register 4 (TIMx\_CCR4)

Address offset: 0x40 Reset value: 0x0000

| 31   | 30   | 29   | 28   | 27   | 26   | 25     | 24         | 23       | 22        | 21   | 20   | 19   | 18   | 17   | 16   |
|------|------|------|------|------|------|--------|------------|----------|-----------|------|------|------|------|------|------|
|      |      |      |      |      |      | CCR4[3 | 1:16] (dep | ending o | n timers) |      |      |      |      |      | •    |
| rw/r   | rw/r       | rw/r     | rw/r      | rw/r | rw/r | rw/r | rw/r | rw/r | rw/r |
| 15   | 14   | 13   | 12   | 11   | 10   | 9      | 8          | 7        | 6         | 5    | 4    | 3    | 2    | 1    | 0    |
|      |      |      |      |      |      |        | CCR4       | [15:0]   |           |      |      |      |      |      |      |
| rw/r   | rw/r       | rw/r     | rw/r      | rw/r | rw/r | rw/r | rw/r | rw/r | rw/r |

Bits 31:16 CCR4[31:16]: High Capture/Compare 4 value (on TIM2)

# Bits 15:0 CCR4[15:0]: Low Capture/Compare value

- 1. if CC4 channel is configured as output (CC4S bits):
  - CCR4 is the value to be loaded in the actual capture/compare 4 register (preload value). It is loaded permanently if the preload feature is not selected in the TIMx\_CCMR2 register (bit OC4PE). Else the preload value is copied in the active capture/compare 4 register when an update event occurs.
  - The active capture/compare register contains the value to be compared to the counter TIMx\_CNT and signalled on OC4 output.
- if CC4 channel is configured as input (CC4S bits in TIMx\_CCMR4 register): CCR4 is the counter value transferred by the last input capture 4 event (IC4). The TIMx\_CCR4 register is read-only and cannot be programmed.

666/1141 DocID022558 Rev 8



# 21.4.17 TIMx DMA control register (TIMx\_DCR)

Address offset: 0x48 Reset value: 0x0000

|   | 15   | 14   | 13   | 12 | 11 | 10       | 9  | 8  | 7    | 6    | 5    | 4  | 3  | 2        | 1  | 0  |
|---|------|------|------|----|----|----------|----|----|------|------|------|----|----|----------|----|----|
| ſ | Res. | Res. | Res. |    |    | DBL[4:0] |    |    | Res. | Res. | Res. |    |    | DBA[4:0] |    |    |
| Ī |      |      |      | rw | rw | rw       | rw | rw |      |      |      | rw | rw | rw       | rw | rw |

Bits 15:13 Reserved, must be kept at reset value.

## Bits 12:8 DBL[4:0]: DMA burst length

This 5-bit vector defines the number of DMA transfers (the timer recognizes a burst transfer when a read or a write access is done to the TIMx\_DMAR address).

00000: 1 transfer, 00001: 2 transfers, 00010: 3 transfers,

...

10001: 18 transfers.

Bits 7:5 Reserved, must be kept at reset value.

# Bits 4:0 DBA[4:0]: DMA base address

This 5-bit vector defines the base-address for DMA transfers (when read/write access are done through the TIMx\_DMAR address). DBA is defined as an offset starting from the address of the TIMx\_CR1 register.

Example:

00000: TIMx\_CR1 00001: TIMx\_CR2 00010: TIMx\_SMCR

...

**Example**: Let us consider the following transfer: DBL = 7 transfers & DBA = TIMx\_CR1. In this case the transfer is done to/from 7 registers starting from the TIMx\_CR1 address.

# 21.4.18 TIMx DMA address for full transfer (TIMx\_DMAR)

Address offset: 0x4C Reset value: 0x0000

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|------|---------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | DMAE | 3[15:0] |    |    |    |    |    |    | •  |
| rw   | rw      | rw | rw | rw | rw | rw | rw | rw |

Bits 15:0 DMAB[15:0]: DMA register for burst accesses

A read or write operation to the DMAR register accesses the register located at the address (TIMx\_CR1 address) + (DBA + DMA index) x 4

where TIMx\_CR1 address is the address of the control register 1, DBA is the DMA base address configured in TIMx\_DCR register, DMA index is automatically controlled by the DMA transfer, and ranges from 0 to DBL (DBL configured in TIMx\_DCR).



# 21.4.19 TIMx register map

TIMx registers are mapped as described in the table below:

Table 127. TIM2/TIM3/TIM4 register map and reset values

| Offset | Register                            | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24      | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16      | 15    | 14  | 13            | 12    | 11              | 10    | 6         | 8    | 7     | 9         | 2                     | 4     | က               | 2     | 1         | 0    |
|--------|-------------------------------------|-----|-----|-----|-----|-----|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|---------|-------|-----|---------------|-------|-----------------|-------|-----------|------|-------|-----------|-----------------------|-------|-----------------|-------|-----------|------|
| 0x00   | TIMx_CR1                            | Res     | Res | Res | Res | Res | Res | Res | Res | Res     | Res   | Res | Res           | Res   | UIFREMAP        | Res   | Ch<br>[1: |      | ARPE  | CN<br>[1: |                       | DIR   | OPM             | URS   | UDIS      | CEN  |
|        | Reset value                         |     |     |     |     |     |     |     |         |     |     |     |     |     |     |     |         |       |     |               |       |                 |       | 0         | 0    | 0     | 0         | 0                     | 0     | 0               | 0     | 0         | 0    |
| 0x04   | TIMx_CR2                            | Res     | Res | Res | Res | Res | Res | Res | Res | Res     | Res   | Res | Res           | Res   | Res             | Res   | Res       | Res  | TI1S  | MN        | /IS[2                 | 2:0]  | CCDS            | Res   | Res       | Res  |
|        | Reset value                         |     |     |     |     |     |     |     |         |     |     |     |     |     |     |     |         |       |     |               |       |                 |       |           |      | 0     | 0         | 0                     | 0     | 0               |       |           |      |
| 0x08   | TIMx_SMCR                           | Res     | Res | Res | Res | Res | Res | Res | Res | SMS[3]  | ETP   | ECE | ET<br>[1:     |       | ı               | ETF   | [3:0]     | ]    | MSM   | T         | S[2:                  | 0]    | occs            | SM    | 1S[2      | :0]  |
|        | Reset value                         |     |     |     |     |     |     |     |         |     |     |     |     |     |     |     | 0       | 0     | 0   | 0             | 0     | 0               | 0     | 0         | 0    | 0     | 0         | 0                     | 0     | 0               | 0     | 0         | 0    |
| 0x0C   | TIMx_DIER                           | Res     | Res | Res | Res | Res | Res | Res | Res | Res     | Res   | TDE | COMDE         | CC4DE | CC3DE           | CC2DE | CC1DE     | UDE  | Res   | TIE       | Res                   | CC4IE | CC3IE           | CC2IE | CC11E     | UIE  |
|        | Reset value                         |     |     |     |     |     |     |     |         |     |     |     |     |     |     |     |         |       | 0   | 0             | 0     | 0               | 0     | 0         | 0    |       | 0         |                       | 0     | 0               | 0     | 0         | 0    |
| 0x10   | TIMx_SR                             | Res     | Res | Res | Res | Res | Res | Res | Res | Res     | Res   | Res | Res           | CC40F | CC3OF           | CC2OF | CC10F     | Res  | Res   | TIF       | Res                   | CC4IF | CC3IF           | CC2IF | CC1IF     | UIF  |
|        | Reset value                         |     |     |     |     |     |     |     |         |     |     |     |     |     |     |     |         |       |     |               | 0     | 0               | 0     | 0         |      |       | 0         |                       | 0     | 0               | 0     | 0         | 0    |
| 0x14   | TIMx_EGR                            | Res     | Res | Res | Res | Res | Res | Res | Res | Res     | Res   | Res | Res           | Res   | Res             | Res   | Res       | Res  | Res   | TG        | Res                   | CC4G  | CC3G            | CC2G  | CC1G      | nG   |
|        | Reset value                         |     |     |     |     |     |     |     |         |     |     |     |     |     |     |     |         |       |     |               |       |                 |       |           |      |       | 0         |                       | 0     | 0               | 0     | 0         | 0    |
|        | TIMx_CCMR1 Output Compare mode      | Res | OC2M[3] | Res | OC1M[3] | OC2CE |     | )C2l<br>[2:0] |       | OC2PE           | OC2FE | CC<br>[1: |      | OC1CE |           | )C1 <b>I</b><br>[2:0] |       | OC1PE           | OC1FE | CC<br>[1: |      |
| 0x18   | Reset value                         |     |     |     |     |     |     |     | 0       |     |     |     |     |     |     |     | 0       | 0     | 0   | 0             | 0     | 0               | 0     | 0         | 0    | 0     | 0         | 0                     | 0     | 0               | 0     | 0         | 0    |
| 0.00   | TIMx_CCMR1<br>Input Capture<br>mode | Res     | Res | Res | Res | Res | Res | Res | Res | Res     | ı     | C2F | -[3:C         | )]    | IC<br>PS<br>[1: | SC    | CC<br>[1: |      | -     | C1F       | [3:0                  | )]    | IC<br>PS<br>[1: | SC    | CC<br>[1: |      |
|        | Reset value                         |     |     |     |     |     |     |     |         |     |     |     |     |     |     |     |         | 0     | 0   | 0             | 0     | 0               | 0     | 0         | 0    | 0     | 0         | 0                     | 0     | 0               | 0     | 0         | 0    |
|        | TIMx_CCMR2 Output Compare mode      | Res | OC4M[3] | Res | OC3M[3] | O24CE |     | )C4I<br>[2:0] |       | OC4PE           | OC4FE | CC<br>[1: |      | OC3CE |           | C3I<br>[2:0]          |       | OC3PE           | OC3FE | CC<br>[1: |      |
| 0.40   | Reset value                         |     |     |     |     |     |     |     | 0       |     |     |     |     |     |     |     | 0       | 0     | 0   | 0             | 0     | 0               |       | 0         | 0    | 0     | 0         | 0                     | 0     | 0               | 0     | 0         | 0    |
| 0x1C   | TIMx_CCMR2 Input Capture mode       | Res     | Res | Res | Res | Res | Res | Res | Res | Res     | ı     | C4F | [3:0          | )]    | IC<br>PS<br>[1: | SC    | CC<br>[1: |      | ı     | C3F       | [3:0                  | )]    | IC<br>PS        | SC    | CC<br>[1: |      |
|        | Reset value                         |     |     |     |     |     |     |     |         |     |     |     |     |     |     |     |         | 0     | 0   | 0             | 0     | 0               | 0     | 0         | 0    | 0     | 0         | 0                     | 0     | 0               | 0     | 0         | 0    |
| 0x20   | TIMx_CCER                           | Res     | Res | Res | Res | Res | Res | Res | Res | Res     | CC4NP | Res | CC4P          | CC4E  | CC3NP           | Res   | ССЗР      | CC3E | CC2NP | Res       | CC2P                  | CC2E  | CC1NP           | Res   | CC1P      | CC1E |
|        | Reset value                         |     |     |     |     |     |     |     |         |     |     |     |     |     |     |     |         | 0     |     | 0             | 0     | 0               |       | 0         | 0    | 0     |           | 0                     | 0     | 0               |       | 0         | 0    |



Table 127. TIM2/TIM3/TIM4 register map and reset values (continued)

| Offset | Register    | 31                | 30                                | 29  | 28   | 27   | 56    | 25  | 24  | 23           | 22  | 21   | 20   | 19    | 18    | 17   | 16  | 15  | 14  | 13  | 12 | 11 | 10   | 6   | æ   | 7    | 9    | 2   | 4 | 3  | 2    | -    | 0 |
|--------|-------------|-------------------|-----------------------------------|-----|------|------|-------|-----|-----|--------------|-----|------|------|-------|-------|------|-----|-----|-----|-----|----|----|------|-----|-----|------|------|-----|---|----|------|------|---|
| 0x24   | TIMx_CNT    | CNT[31] or UIFCPY |                                   |     | (TIN | М2 ( | only  |     |     | T[30<br>ed o |     | -    | the  | r tim | iers) | 1    |     |     |     |     |    |    |      | (   | CNT | [15: | 0]   |     |   |    |      |      |   |
|        | Reset value | 0                 | 0                                 | 0   | 0    | 0    | 0     | 0   | 0   | 0            | 0   | 0    | 0    | 0     | 0     | 0    | 0   | 0   | 0   | 0   | 0  | 0  | 0    | 0   | 0   | 0    | 0    | 0   | 0 | 0  | 0    | 0    | 0 |
| 0x28   | TIMx_PSC    | Res               | Res                               | Res | Res  | Res  | Res   | Res | Res | Res          |     | Res  | Res  | Res   | Res   | Res  | Res |     |     |     |    |    |      | F   | PSC | [15: | 0]   |     |   |    |      |      |   |
|        | Reset value |                   |                                   |     |      |      |       |     |     |              |     |      |      |       |       |      |     | 0   | 0   | 0   | 0  | 0  | 0    | 0   | 0   | 0    | 0    | 0   | 0 | 0  | 0    | 0    | 0 |
| 0x2C   | TIMx_ARR    |                   |                                   | (T  | IM2  | a o  | nly,  |     |     | 31:1<br>d or |     | e ot | her  | time  | ers)  |      |     |     |     |     |    |    |      | ļ   | ARR | [15: | 0]   |     |   |    |      |      |   |
|        | Reset value | 1                 | 1                                 | 1   | 1    | 1    | 1     | 1   | 1   | 1            | 1   | 1    | 1    | 1     | 1     | 1    | 1   | 1   | 1   | 1   | 1  | 1  | 1    | 1   | 1   | 1    | 1    | 1   | 1 | 1  | 1    | 1    | 1 |
| 0x30   |             |                   |                                   |     |      |      |       |     |     |              |     | ı    |      |       | Rese  | erve | d   |     |     |     |    |    |      |     |     |      |      |     |   |    |      |      |   |
| 0x34   | TIMx_CCR1   |                   | CCR1[31:16] CCR1[15:0] CCR1[15:0] |     |      |      |       |     |     |              |     |      |      |       |       |      |     |     |     |     |    |    |      |     |     |      |      |     |   |    |      |      |   |
|        | Reset value | 0                 | 0                                 | 0   | 0    | 0    | 0     | 0   | 0   | 0            | 0   | 0    | 0    | 0     | 0     | 0    | 0   | 0   | 0   | 0   | 0  | 0  | 0    | 0   | 0   | 0    | 0    | 0   | 0 | 0  | 0    | 0    | 0 |
| 0x38   | TIMx_CCR2   |                   |                                   | (1  | ГІМ2 | 2 on | ly, r |     |     | [31:<br>d on |     | oth  | er t | ime   | rs)   |      |     |     |     |     |    |    |      | С   | CR2 | 2[15 | :0]  |     |   |    |      |      |   |
|        | Reset value | 0                 | 0                                 | 0   | 0    | 0    | 0     | 0   | 0   | 0            | 0   | 0    | 0    | 0     | 0     | 0    | 0   | 0   | 0   | 0   | 0  | 0  | 0    | 0   | 0   | 0    | 0    | 0   | 0 | 0  | 0    | 0    | 0 |
| 0x3C   | TIMx_CCR3   |                   |                                   | (7  | гім2 | 2 on | ly, r |     |     | [31:<br>d on |     | oth  | er t | ime   | rs)   |      |     |     |     |     |    |    |      | С   | CR3 | 3[15 | :0]  |     |   |    |      |      |   |
|        | Reset value | 0                 | 0                                 | 0   | 0    | 0    | 0     | 0   | 0   | 0            | 0   | 0    | 0    | 0     | 0     | 0    | 0   | 0   | 0   | 0   | 0  | 0  | 0    | 0   | 0   | 0    | 0    | 0   | 0 | 0  | 0    | 0    | 0 |
| 0x40   | TIMx_CCR4   |                   |                                   | (   | ГІМ2 | 2 on | ly, r |     |     | [31:<br>l on | _   | oth  | er t | ime   | rs)   |      |     |     |     |     |    |    |      | С   | CR4 | 1[15 | :0]  |     |   |    |      |      |   |
|        | Reset value | 0                 | 0                                 | 0   | 0    | 0    | 0     | 0   | 0   | 0            | 0   | 0    | 0    | 0     | 0     | 0    | 0   | 0   | 0   | 0   | 0  | 0  | 0    | 0   | 0   | 0    | 0    | 0   | 0 | 0  | 0    | 0    | 0 |
| 0x44   |             |                   |                                   |     |      |      |       |     |     |              |     |      |      |       | Rese  | erve | d   |     |     |     |    |    |      |     |     |      |      |     |   |    |      |      |   |
| 0x48   | TIMx_DCR    | Res               | Res                               | Res | Res  | Res  | Res   | Res | Res | Res          | Res | Res  | Res  | Res   | Res   | Res  | Res | Res | Res | Res |    | DE | 3L[4 | :0] |     | Res  | Res  | Res |   | DE | BA[4 | 1:0] |   |
|        | Reset value |                   |                                   |     |      |      |       |     |     |              |     |      |      |       |       |      |     |     |     |     | 0  | 0  | 0    | 0   | 0   |      |      |     | 0 | 0  | 0    | 0    | 0 |
| 0x4C   | TIMx_DMAR   | Res               | Res                               | Res | Res  | Res  | Res   | Res | Res | Res          | Res | Res  | Res  | Res   | Res   | Res  | Res |     |     |     |    |    |      | D   | MAE | 3[15 | 5:0] |     |   |    |      |      |   |
|        | Reset value |                   |                                   |     |      |      |       |     |     |              |     |      |      |       |       |      |     | 0   | 0   | 0   | 0  | 0  | 0    | 0   | 0   | 0    | 0    | 0   | 0 | 0  | 0    | 0    | 0 |

Refer to *Section 3.2.2: Memory map and register boundary addresses* for the register boundary addresses.

